/*
 * Copyright © 2020 www.noark.xyz All Rights Reserved.
 * 
 * 感谢您选择Noark框架，希望我们的努力能为您提供一个简单、易用、稳定的服务器端框架 ！
 * 除非符合Noark许可协议，否则不得使用该文件，您可以下载许可协议文件：
 * 
 * 		http://www.noark.xyz/LICENSE
 *
 * 1.未经许可，任何公司及个人不得以任何方式或理由对本框架进行修改、使用和传播;
 * 2.禁止在本项目或任何子项目的基础上发展任何派生版本、修改版本或第三方版本;
 * 3.无论你对源代码做出任何修改和改进，版权都归Noark研发团队所有，我们保留所有权利;
 * 4.凡侵犯Noark版权等知识产权的，必依法追究其法律责任，特此郑重法律声明！
 */
package com.company.qqsg.core;

import static xyz.noark.log.LogHelper.logger;

import com.company.qqsg.core.netty.QqsgPacket;

import xyz.noark.core.annotation.Controller;
import xyz.noark.core.annotation.controller.CommandMapping;
import xyz.noark.core.annotation.controller.ExecThreadGroup;
import xyz.noark.core.network.Session.State;

/**
 * 心跳包，使用Netty的Work线程直接处理了
 *
 * @author 小流氓(176543888@qq.com)
 */
@Controller(threadGroup = ExecThreadGroup.NettyThreadGroup)
public class HeartbeatController {

	/**
	 * 心跳协议,这里要注入请求封包来判定一个属性
	 */
	@CommandMapping(opcode = "system@heartbeat", state = State.ALL)
	public String heartbeat(QqsgPacket packet) {
		logger.debug("心跳协议");

		// 感觉没有什么用，只是演示注入封包的功能
		if (packet.getSource() == 1) {
			return JsonHelper.buildSuccess();
		}
		return JsonHelper.buildSuccess();
	}
}